package collection;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/**
 * 对字符串集合进行排序
 */
public class SortString {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("王克晶");
        list.add("传奇老师很帅");
        list.add("伟超老师");
        System.out.println("list原始数据: "+list); //[王克晶, 传奇老师很帅, 伟超老师]

        Collections.sort(list, new Comparator<String>() {
            /*
              compare()方法用于定义o1和o2比较大小的规则，并且通过返回值表达大小关系
              返回值实现的要求:-----------不用纠结，记住下面的结论即可
                1)如果返回值>0则表达式的是o1>o2
                2)如果返回值<0则表达式的是o1<o2
                3)如果返回值=0则表达式的是o1=o2
              结论:
                1)前面的-后面的-------------升序
                2)后面的-前面的-------------降序
             */
            public int compare(String o1, String o2) {
                //return o1.length()-o2.length(); //升序
                return o2.length()-o1.length(); //降序
            }
        });
        System.out.println("list排序后数据:"+list);

        /*
        List<String> list = new ArrayList<>();
        list.add("jack");
        list.add("rose");
        list.add("tom");
        list.add("jerry");
        list.add("black");
        list.add("Kobe");
        System.out.println("list原始数据: "+list); //[jack, rose, tom, jerry, black, Kobe]
        //对英文字符串排序时，会按首字母大ASCII码来排
        //若首字母相同，则比较第2个字母的ASCII码，以此类推
        Collections.sort(list); //升序
        System.out.println("list排序后数据:"+list); //[Kobe, black, jack, jerry, rose, tom]
        */
    }
}





















